Backdrop

프로그래머스 ▸ 코딩 기초 트레이닝

배열 만들기 2
0

문제 설명

정수 lr이 주어졌을 때, l 이상 r이하의 정수 중에서 숫자 "0"과 "5"로만 이루어진 모든 정수를 오름차순으로 저장한 배열을 return 하는 solution 함수를 완성해 주세요.

만약 그러한 정수가 없다면, -1이 담긴 배열을 return 합니다.

제한사항

  • 1 ≤ lr ≤ 1,000,000

입출력 예

lrresult
5555[5, 50, 55, 500, 505, 550, 555]
1020[-1]

입출력 예 설명

입출력 예 #1

  • 5 이상 555 이하의 0과 5로만 이루어진 정수는 작은 수부터 5, 50, 55, 500, 505, 550, 555가 있습니다. 따라서 [5, 50, 55, 500, 505, 550, 555]를 return 합니다.

입출력 예 #2

  • 10 이상 20 이하이면서 0과 5로만 이루어진 정수는 없습니다. 따라서 [-1]을 return 합니다.

풀이

이론

function solution(l, r) {
  const answer = [];
  for (let i = l; i <= r; i++) {
    if ([...String(i)].every(c => c === '0' || c === '5')) {
      answer.push(i);
    }
  }
 
  return answer.length ? answer : [-1];
}

every() 메서드를 사용하면 주어진 조건을 만족하는지 확인할 수 있어요.

이 코드를 정규표현식으로 바꾸면 아래와 같아요.

function solution(l, r) {
  const answer = [];
  for (let i = l; i <= r; i++) {
    if (String(i).match(/^[05]+$/)) {
      answer.push(i);
    }
  }
 
  return answer.length ? answer : [-1];
}

코드

function solution(l, r) {
  const answer = [];
  for (let i = l; i <= r; i++) {
    if (String(i).match(/^[05]+$/)) {
      answer.push(i);
    }
  }
 
  return answer.length ? answer : [-1];
}